<!-- 标注摆放 -->
<template>
    <div>
        <el-card>
            <template #header>
                <span class="title-span">API基础信息</span>
            </template>
            <!-- // 两个输入框  一个是名称  一个是描述 -->
            <el-form label-width="100">
                <el-form-item label="节点名称：">
                    <el-input v-model="props.showFlowData.data.label"></el-input>
                </el-form-item>
                <el-form-item label="描述：">
                    <el-input v-model="props.showFlowData.data.desc" type="textarea"></el-input>
                </el-form-item>
            </el-form>
        </el-card>

        <el-card style="margin-top: 10px">
            <template #header>
                <span class="title-span">API状态</span>
            </template>

            <el-form label-width="100">
                <el-form-item label="名称：">
                    <el-input v-model="popShowData.APIState.name" disabled></el-input>
                </el-form-item>
                <el-form-item label="类型：">
                    <el-input v-model="popShowData.APIState.type" disabled></el-input>
                </el-form-item>
            </el-form>
        </el-card>

        <el-card style="margin-top: 10px">
            <template #header>
                <span class="title-span">API输入</span>
            </template>


            <el-form label-width="100">
                <el-form-item label="名称：">
                    <el-input v-model="popShowData.APIInput.dataOne.name" disabled></el-input>
                </el-form-item>
                <el-form-item label="类型：">
                    <el-input v-model="popShowData.APIInput.dataOne.type" disabled></el-input>
                </el-form-item>
                <el-form-item label="值：">
                    <el-select v-model="popShowData.APIInput.dataOne.selectValue">
                        <el-option v-for="(item, index) in drawing_documents_selectList" :key="index"
                            :label="item.data.label.slice(0, -4)" :value="item.id"></el-option>
                    </el-select>
                </el-form-item>
            </el-form>
            <el-divider />

            <el-form label-width="100">
                <el-form-item label="名称：">
                    <el-input v-model="popShowData.APIInput.dataTwo.name" disabled></el-input>
                </el-form-item>
                <el-form-item label="类型：">
                    <el-input v-model="popShowData.APIInput.dataTwo.type" disabled></el-input>
                </el-form-item>
                <el-form-item label="值：">
                    <el-select v-model="popShowData.APIInput.dataTwo.selectValue" placeholder="创建图纸文件-新图纸图页">
                        <el-option v-for="(item, index) in drawing_sheet_selectList" :key="index"
                            :label="item.data.label" :value="item.id"></el-option>
                    </el-select>
                </el-form-item>
            </el-form>
            <el-divider />
            <el-form label-width="100">
                <el-form-item label="名称：">
                    <el-input v-model="popShowData.APIInput.dataThree.name" disabled></el-input>
                </el-form-item>
                <el-form-item label="类型：">
                    <el-input v-model="popShowData.APIInput.dataThree.type" disabled></el-input>
                </el-form-item>
                <el-form-item label="值：">
                    <el-select v-model="popShowData.APIInput.dataThree.selectValue">
                        <el-option v-for="(item, index) in view_selectList" :key="index" :label="item.data.label"
                            :value="item.id"></el-option>
                    </el-select>
                </el-form-item>
            </el-form>
            <el-divider />

            <el-form label-width="100">
                <el-form-item label="名称：">
                    <el-input v-model="popShowData.APIInput.dataFour.name" disabled></el-input>
                </el-form-item>
                <el-form-item label="类型：">
                    <el-input v-model="popShowData.APIInput.dataFour.type" disabled></el-input>
                </el-form-item>
                <el-form-item label="值：">
                    <el-select v-model="popShowData.APIInput.dataFour.selectValue">
                        <el-option label="图页视图" value="MainView" />
                        <el-option label="背景视图" value="BackgrounView" />
                        <el-option label="主视图" value="Front" />
                        <el-option label="背视图" value="Rear" />
                        <el-option label="左视图" value="Left" />
                        <el-option label="右视图" value="Right" />
                        <el-option label="俯视图" value="Top" />
                        <el-option label="仰视图" value="Bottom" />
                        <el-option label="轴侧视图" value="ShaftSide" />
                    </el-select>
                </el-form-item>
            </el-form>


        </el-card>
        <el-card style="margin-top: 10px">
            <template #header>
                <span class="title-span">API输出</span>
            </template>

            <div v-for="(item, index) in APIOutput" :key="index">
                <el-form label-width="100">
                    <el-form-item label="名称：">
                        <el-input v-model="item.name" disabled></el-input>
                    </el-form-item>
                    <el-form-item label="类型：">
                        <el-input v-model="item.type" disabled></el-input>
                    </el-form-item>
                </el-form>
            </div>
        </el-card>
    </div>
</template>

<script setup>
import { ref, defineProps, onMounted, watch } from 'vue';
import flowNodesStore from '@/store/modules/flowNodes'
const { proxy } = getCurrentInstance();
const flowNodes = flowNodesStore()
const props = defineProps({
    // Define props here
    showFlowData: {
        type: Object,
    },
    drawer: {
        type: Boolean,
    },
    recapture: {
        type: Boolean
    },
    inputSelectNodeIds: {
        type: Array
    }
});
const popShowData = ref({
    APIBaseData: {
        name: '标注摆放',
        desc: '通过数据，获取数据的固有属性',
    },
    APIState: {
        name: '成功',
        type: '布尔'
    },
    APIInput: {
        dataOne: {
            name: '图纸文件',
            type: '2D文档',
            selectValue: '',
        },
        dataTwo: {
            name: '图纸图页',
            type: '图页',
            selectValue: '',
        },
        dataThree: {
            name: '创建视图选择',
            type: '枚举',
            selectValue: '',
        },
        dataFour: {
            name: '视图选择',
            type: '枚举',
            selectValue: '',
        },
    },
    APIOutput: []
})

const drawing_documents_selectList = computed(() =>
    flowNodes.getFlowNodes()
        .filter(node => props.inputSelectNodeIds.includes(node.id) && node.data?.methodName === 'createDrawing')
        .map(node => {
            const newNode = JSON.parse(JSON.stringify(node));
            const label = newNode.data?.label;
            if (typeof label === 'string') {
                newNode.data.label = `${label}-图纸页`;
            }
            return newNode;
        })
);

const originalDrawingSheetSelectList = computed(() =>
    flowNodes.getFlowNodes()
        .filter(node =>
            props.inputSelectNodeIds.includes(node.id) &&
            node.data?.methodName === 'createSheet'
        )
        .map(node => {
            const { data } = node;
            const newLabel =  data.label;
            return {
                ...node,
                data: {
                    ...data,
                    label: newLabel
                }
            };
        })
);

const drawing_sheet_selectList = computed(() => [
    ...drawing_documents_selectList.value,
    ...originalDrawingSheetSelectList.value
]);

const view_selectList = computed(() => {
    let nodeList = flowNodes.getFlowNodes();
    const resultList = nodeList.filter(node => props.inputSelectNodeIds.includes(node.id)).filter(node => node.data.methodName == 'createViews')
    return resultList;
});

const node_data = computed(() => {
    let obj = {
        //固定值
        positionFlag: props.showFlowData.data.positionFlag,
        methodName: props.showFlowData.data.methodName,

        // 自定义属性
        input2DData: popShowData.value.APIInput.dataOne.selectValue, //2D文件
        sheetName: popShowData.value.APIInput.dataTwo.selectValue, //2D纸业

        inputView: popShowData.value.APIInput.dataThree.selectValue,
        view: popShowData.value.APIInput.dataFour.selectValue, // 视图
    }
    return obj;
});

const APIOutput = computed(() => {

    const allCheckLists = [{
        name: '标注摆放',
        type: '视图'
    }];
    return allCheckLists;
});

// watch(() => props.drawer, (val) => {
//     if (!val) {
//         setData();// 更新数据
//     }
// }, { deep: true }, { immediate: true })

watch(() => popShowData.value, (val) => {
    if (val) {
        setData();// 更新数据
    }
}, { deep: true }, { immediate: true })

watch(() => props.recapture, (val) => {
    reset();
    getList();
}, { deep: true }, { immediate: true })


watch(() => APIOutput.value, (val) => {
    popShowData.value.APIOutput = val
})

onMounted(() => {
    getList();
    setData();
})
const getList = () => {
    if (props.showFlowData.id) {
        if (flowNodes.getFlowNodesById(props.showFlowData.id)) {
            let nodeData = flowNodes.getFlowNodesById(props.showFlowData.id);
            if (nodeData.data.popShowData) {
                popShowData.value = JSON.parse(JSON.stringify(nodeData.data.popShowData))
            }
        }
    }
}
const setData = () => {
    let nodeData = flowNodes.getFlowNodesById(props.showFlowData.id);
    // 如果找到了该节点，则更新数据
    if (nodeData) {
        nodeData.data.popShowData = popShowData.value
        nodeData.data.data = node_data.value
        flowNodes.setFlowNodesById(props.showFlowData.id, nodeData)

    }
}
const reset = () => {
    popShowData.value = {
        APIBaseData: {
            name: '标注摆放',
            desc: '通过数据，获取数据的固有属性',
        },
        APIState: {
            name: '成功',
            type: '布尔'
        },
        APIInput: {
            dataOne: {
                name: '图纸文件',
                type: '2D文档',
                selectValue: '',
            },
            dataTwo: {
                name: '图纸图页',
                type: '图页',
                selectValue: '',
            },
            dataThree: {
                name: '创建视图选择',
                type: '枚举',
                selectValue: '',
            },
            dataFour: {
                name: '视图选择',
                type: '枚举',
                selectValue: '',
            },
        },
        APIOutput: []
    }
}
</script>

<style scoped>
/* Your component styles go here */
</style>